CpE 272 Lab

Lab 7: Modular Design and Library Components

Prepared By:

Olujide Jacobs

Prepared For:

Matt Grubb

October 14, 2013.

**Introduction**

The aim of this lab was to teach students how to simplify the process of designing complex circuits using modular design, and also how make use of the contents in the Quartus II library.

**Experiment I**

The objective of this part of the lab was to design, program and verify the operations of a 4-bit full adder by the way of the modular design technique.

**Methodology**

To achieve this, the group wrote the VHDL code for a 1-bit full adder with inputs X1, Y1 and C0, and outputs Z1 and Z2 where Z1 represented the sum output and Z2 the carryout, finally the file was saved as “light”. Next a new VHDL file named ‘light2’ was created where the inputs, outputs and signals were defined using vectors instead of listing each one of them individually. So inputs eight inputs X1 and Y1 from 3 down to 0, five outputs from Z1 from 4 down to 0 and three signals Z2 from 2 down to 0 were defined. Next the group designed the 4-bit full adder by instantiating the component light, which is the 1-bit full adder design entity previously defined. The component light was instantiated four times, and the connections between all four full adders were made by port mapping the inputs and outputs of each full adder to their correct positions. The schematics for the 4-bit full adder served as a guide while port mapping, and it can be seen below in figure 1, followed by the VHDL code of the 1 and 4 bit adder respectively.

![http://upload.wikimedia.org/wikipedia/commons/thumb/f/fe/4-Bit_Full_Adder.svg/400px-4-Bit_Full_Adder.svg.png](data:image/png;base64,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)

Figure 4-bit full adder

**Code for 1-bit full adder**

LIBRARY ieee;

USE ieee.std\_logic\_1164.all;

ENTITY light IS

PORT (

X1 : IN STD\_LOGIC;

Y1 : IN STD\_LOGIC;

C0 : IN STD\_LOGIC;

Z1 : OUT STD\_LOGIC;

Z2 : OUT STD\_LOGIC

);

END light;

ARCHITECTURE Behavior OF light IS

BEGIN

Z1 <= C0 xor (X1 xor Y1);

Z2 <= ((X1 xor Y1) and C0) or (X1 and Y1);

END Behavior;

**Code for 4-bit full adder**

LIBRARY ieee;

USE ieee.std\_logic\_1164.all;

ENTITY light2 IS

PORT (

X1 : IN STD\_LOGIC\_VECTOR(3 downto 0);

Y1 : IN STD\_LOGIC\_VECTOR(3 downto 0);

Z1 : OUT STD\_LOGIC\_VECTOR(4 downto 0)

);

END light2;

ARCHITECTURE Behavior OF light2 IS

signal Z2 : STD\_LOGIC\_VECTOR (2 downto 0);

component light

PORT (

X1 : IN STD\_LOGIC;

Y1 : IN STD\_LOGIC;

C0 : IN STD\_LOGIC;

Z1 : OUT STD\_LOGIC;

Z2 : OUT STD\_LOGIC

);

end component;

BEGIN

adder1 : light port map(X1(0), Y1(0), '0', Z1(0), Z2(0));

adder2 : light port map(X1(1), Y1(1), Z2(0), Z1(1), Z2(1));

adder3 : light port map(X1(2), Y1(2), Z2(1), Z1(2), Z2(2));

adder4 : light port map(X1(3), Y1(3), Z2(2), Z1(3), Z1(4));

END Behavior;

After port mapping, the code was compiled and switches and LEDs were assigned to the inputs and outputs respectively. Finally the code was compiled again and then programmed on the FGPA and tested.

**Result**

The circuit worked as it should, the right output was gotten for the different input combinations tested. (1010 + 1010 = 10110), (1010 + 1011 = 10101), (0111 + 1001 = 10000)

**Experiment II**

The objective here is to download a comparator, which compares the magnitude of two n-bit numbers, from the Quartus II library unto the Altera DE2 board and verify its operation.

**Methodology**

Following the instructions provided in the lab handout, the group opened the “mega wizard manager” and “LPM\_COMPARE” from the list of available LPMs. A VHDL output file was chosen and named “cmp.vhd”. Next the group chose three output types to be used namely equal, greater-than and less-than outputs. Afterwards files “cmp.cmp” and “cmp\_inst.vhd”, the two files that contained the declaration and instantiation VHDL codes which were required to be generated by the wizard were chosen. The inputs of the comparator were defined using vectors and are data from 3 down to 0 and datab also from 3 down to 0, with the three outputs AeB, AgB and AlB representing A=B, A>B and A<B.The VHDL code can be seen below

**VHDL Code**

LIBRARY ieee;

USE ieee.std\_logic\_1164.all;

LIBRARY lpm;

USE lpm.all;

ENTITY cmp IS

PORT

(

dataa : IN STD\_LOGIC\_VECTOR (3 DOWNTO 0);

datab : IN STD\_LOGIC\_VECTOR (3 DOWNTO 0);

AeB : OUT STD\_LOGIC ;

AgB : OUT STD\_LOGIC ;

AlB : OUT STD\_LOGIC

);

END cmp;

ARCHITECTURE SYN OF cmp IS

SIGNAL sub\_wire0 : STD\_LOGIC ;

SIGNAL sub\_wire1 : STD\_LOGIC ;

SIGNAL sub\_wire2 : STD\_LOGIC ;

COMPONENT lpm\_compare

GENERIC (

lpm\_representation : STRING;

lpm\_type : STRING;

lpm\_width : NATURAL

);

PORT (

dataa : IN STD\_LOGIC\_VECTOR (3 DOWNTO 0);

datab : IN STD\_LOGIC\_VECTOR (3 DOWNTO 0);

AlB : OUT STD\_LOGIC ;

AgB : OUT STD\_LOGIC ;

AeB : OUT STD\_LOGIC

);

END COMPONENT;

BEGIN

AlB <= sub\_wire0;

AgB <= sub\_wire1;

AeB <= sub\_wire2;

lpm\_compare\_component : lpm\_compare

GENERIC MAP (

lpm\_representation => "UNSIGNED",

lpm\_type => "LPM\_COMPARE",

lpm\_width => 4

)

PORT MAP (

dataa => dataa,

datab => datab,

AlB => sub\_wire0,

AgB => sub\_wire1,

AeB => sub\_wire2

);

END SYN;

Finally switches and LEDs were assigned to the inputs and outputs respectively, the code was compiled, downloaded unto the FGPA and tested.

**Result**

Different values for A and B were used in the test, and on each occasion the comparator correctly signaled whether A was equal to, less than or greater than B through the means of the respective LED lighting up.

**Conclusion**

This experiments performed in the lab were all successful, and I learned how to use modular design to simplify building complex circuits, and also how to make use of the comparator from the Quartus IIs’ library.